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(54) A system and method for server selection for mirrored sites 



(57) The present Invention is a system and method 
for providing server selection for mirrored sites. In a pre- 
ferred embodiment, a user requests an address j^la a 
lo caLoaoTe seryLce. and the local name servic e requests 
the address. from a seryer, e xarriples of vyhlch Include 
an author itat Iv e _ nam e^se rye r. and a Pptlmizer^^Name 
ServeT(ONS) ,_lf the_O NS. has_alr .ead v_calcu late d a best 
7oijt' eLjftrtilch^a p pllesJoJhjs_u3.ejLja nd a predetermined 



time applying to the best route has not yet expired, then 
the ONS replies to the user with the best route server. 
If, however, the best route has not been determined or 
the predetermined time for the best route has expired, 
then the ONS replies to the user via a selection scheme, 
such as a round robin scheme, and also initiates a best 
route determination to determine which is the best route 
for this user. 
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Description 

BACKGROUND OF THE INVENTION 

1. Field of the Invention 

[0001] The present invention relates to accessing da- 
ta on the Internet via a computer system. In particular, 
the present invention relates to a system and method 
for selecting a server for requested data. 

2. Description of the Related Art 

[0002] With the growing popularity of the Internet, pro- 
viding speedy access to a requested location on the In- 
ternet is fast becoming a major issue. When a popular 
web page is hosted by a single computer, the Internet 
traffic to the computer can be ovenwhelming. To solve 
this problem, several computers can be utilized to host 
the web page such that each hosting computer, typically 
referred to as a server, contains a copy of the web page. 
If there are many servers at the same location, then the 
network connection to that location can become choked 
during a time of high Intemet traffic. To avoid choking 
^he network connection, mirrored servers can be located 
at differenLsites. These sites are he rein referred to as 
m irrored sites . The use of multiple computers to host a 
w^page js typicall yjgferredjo js mirroring servers. 
[0003] Figs. 1 and 2 illustrate basic communication 
lines in the lnt^met^gj|s a diagraiTi_showing the ba- 
sic organization of the Jntemet. Groups of networks 
100A-100C, 100D-100F, and 100G-100I. are shown to 
be connected via routers 102A-102F. A set of networks 
and routers combine to create an autonomous system 
(AS). A collection of networks within an AS can consist- 
ently perform various tasks with standards and proto- 
cols within the AS 104A-104C. Each AS 104A-104C is 
shown to be coupled with another AS via a gateway 
106A-106B. Gateways 106A-106B typically contain 
enough information about the Internet such that each 
gateway has data related to every other gateway. Each 
gateway typically has routing tables which contains in- 
formation relating to a route from point A to point B for 
the entire Internet. 

[0004] Fig. 2 is a block diagram illustrating a path tak- 
en by a user^s request for a particular address, and the 
path taken in receiving that address. Fig. 2 shows user 
200 requesting an address, such as www.sun.com, from 
a local name sen/ice 201 . The user'slocal names ervice 
20Jjnna v_ be a service such as Netco m or AT&T. The 
local name service 201 t heji requests the add ress for 
suQj^QPutor La do main name service (DNS) server 
202a. Typjca!Jy,Jhe_DNS server 202a r equests the ad- 
dressforsuacom ffom^anotherJDN ^^^ which 
in turn wiLtV PicaTlv request another DNS serve r 202c. 
This series of requests continues until the req uest for 
the address of sun.com arrives at an authoritative name 
sen/ice (Authoritative NS) 204. The authoritative NS 204 



can determine the address of sun.com. In the example 
shown in Fig. 2. mirrored servers IP12 06a, IP2 206b, 
and IP3 206c are shown to be utilized. The authoritative 
NS 204 determines which server 206a-206c address to 

s respondi athe request for an address such as sun.c om. 
The mirrored servers 2 06a-2Q6 c can be located in var- 
ious geographically diverse locations such as an east 
I^ atton 7westlocation~anq~an buropean location. An 
advantage of having mirrored sen/ers located at various 

10 locations is that multiple locations_can_accommodate 
mor e Intemet traffic than a single locatio n. A further ad- 
vantage of having mirrored servers in various locations 
is that if the user is located in Europe, accessing the 
European server 206c is most likely faster than the Eu- 

J5 ropean user accessing the west coast server 206c. 
[0005] The authoritative NS 204 can select a mirrored 
se rver based on severajla ctors. These factors include 
the load on each server or the user's location. Ideally, 
the requested address should be returned to the user 

20 very quickly and download into the user's computer sys- 
tem as quickly as possible. The time between the re- 
quest being sent out and the address being received is 
referred to latency. The time it takes to download the 
requested data is typically determined by the bandwidth. 

25 [0006] Once the authoritative NS 204 determines 
which mirrored server the user should access, the au- 
thoritative NS 204 returns the address of the selected 
mirrored server back to the user via the route taken by 
the u^erlsjeqt^t. 

30 [0007] A problem arises when a user bookmarks a 
particular web page. When a user bookmarks a partic- 
ular web page, the user is typically bookmarking a par- 
ticular server. For instance, if a user in California is sent 
to the European sender 206c, and the user bookmarks 

3S the fjage. then when the user recalls the page from a 
bookmark-, then the user will return to the European 
sen/er206c. However, the s econd time th e user access- 
es the European server 2066^ the~European server may 
be heavily loaded, while the eastern server 206a may 

40 have a light load. In that situation, it may be better for 
the user to access the eastern server 206a rather than 
the European server 206c. Since the user has book- 
marked a Bacticujag^grver . whatever scheme was insti- 
tuted in the aut horitative N S 204 is typically defeated. 

45 Additionally, if the user has bookmarked a particular 
server, it is better for the user if_the_bookmaik§ds§rver 
can be accessed quickly . For instance, the user i n Cal- 
if ornia ma vLbe.i o^a more optimal situation if the bo ok- 
marked server was located closer to the user than t he 

^0 European ^efl/er_^p6 c. These potential problems relat- 
ed to bookmarking typically occur i n Http redirect mec h- 
nniTm? whrh rirf^n^t trrmr fpareg^ to tha ^jse r 
[0008] The address given by the authoritative NS 204 
isJypically.va!idjo/_a.pcedeterminedJimited amount of 

55 tinoe. If the user requests access to the same web page 
which the user had previously requested, the user 
should ask the authoritative NS 204 again for the ad- 
rims.tt ni thp vyph^paf^o if ihe^ p revJous amount o f time 
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has expired since the last request. In this nnanner, the 
authoritative NS 204 can reevaluate the situation a nd 
re determine which server to route tje user. 
[oS^ Several schemes for determining" which of the 
mi rrored sg rvAfQ In iigp has been utilized by variou s au- 
th oritative NS's 20 4. One such scheme is a load balanc- 
ing named (LB named) system scheme. In this scheme, 
the authoritative NS 204 det ermines how many users 
a re being served by each mirrored server andjou tes a 
n ew usertOLthe rn irrored server wit^h t^e least loa d. The 
load is determined by the number of people accessing 
the server at a given time and the power of the server. 
The problem with the LB-named scheme is that al- 
though it factors load balancing, the sch eme is indiffe r- 
ent to, the location of the user. The location of the user 
is typically a factor in determining latency. If the user is 
very far from the assigned server, then It will typically 
take longer to access the far server than if the user was 
very close to the server, even if the closer serveris load 
is heavier than the farther serveris load. 
[0010] Another scheme which is conventionally used 
by the authoritative NS 204 is the round robin DNS. The 
round robin DNS simply takes turns on which server is 
to be used. The problem with the round robin DNS 
scheme is that it does not take into consideration the 
various loads of the mirrored servers at any given time. 
Additionally, the round robin DNS scheme also fails to 
take into consideration the location of the user. Accord- 
ingly, the two factors of latency and bandwidth are not 
typically considered in the round robin scheme. 
[0011] Yet another scheme can be referred to as an 
AS hop count scheme. In the AS hop count scheme, 
autonomous systems located between the user and a 
mirrored server are counted and the server with the 
smallest number of autonomous systems located be- 
tween the user and the sen/er is selected for use by that 
user. The AS hop count scheme assumes that the fac- 
tors of bandwidth and latency are approximately reflect- 
ed in the number of autonomous systems located be- 
tween the user and a server However, In practice, au- 
tonomous systems can be various sizes and a small au- 
tonomous systems typically cannot accommodate as 
much traffic as a large autonomous system. According- 
ly, a route including a larger number of autonomous sys- 
tems may actually be faster than a route with a smaller 
number of autonomous systems if a very small As is in- 
cluded in the route with the smaller number of autono- 
mous systems. 

[0012] What is needed is a system and method for a 
server selection for mirrored sites which optimizes ac- 
cess and is transparent to the user. The ppsentjnyen- 
tion addresses suc h a need. 

SUMMARY OF THE INVENTION 

[001 3] The present invention Js a^vstem and m ethod 
for providing server selection for mirrored sites. In a pre- 
ferred embodiment, a user requests an address via a 



local name service, and th e local name service requests 
the a ddress from a servaL example s of which i nclude 
an authoritative name server, and an Optimizer Name 
ServeTJONS). I f the ONS jias already„calculate d a best 
ro ute_which applies to thls^usex.aad_apxgclejern ii^ 
ti me applying tojhe_.best ro u t.e,bas,oot^ y et expired, then 
th e ONS j^JjesJpJh.e,use/ jwJ^hJhe^estXQu^^ 
If, however, the best route has not been determined or 
the predetermined time f or the best route has expired, 
then the ONS replies to the user via a selection sch eme. 
-1 su ch as a round x Qbin_schem e, and_alsoJ aiUatas=abest 
/ routeL determination to determine which is the bes t route 
/ for this user 

In the preferred embodiment, the best route 
determination begins with requesting alj^the mirrored 
servers for a round trip time to the requesting local name 
server used by the user Each mirrored server then 
sends a name query to the local name server (LNS). 
The LNS then would reply with an error message stating 
that no such name exists. Each mirrored server then de- 
termines its own round trip time for the name query and 
the error message and sends the round trip time to the 
ONS. The ONS receives the round tri p times of all mir- 
ro red servers and determines which mirrored se rver has 
th e shortesL ro.und.tr.ipJime (best route). The best route 
determination is then stored for a predetermined time. 
If the sarjie LNS requests an address from the ONS 
within that predetermined time, then the mirrored server 
withjhe best route for that particular LNS is utilized. 
[0015] Alternatively, rather than each mirrored server 
sending a name query to the LNS, each mirrored server 
sends an Internet control message protocol (I CMP) 
echo packet to the LNS. When the echo packet is re- 
turned from the LNS, then a round trip time can be de- 
termined by each mirrored server 
[0016] A method according to an embodiment of the 
present invention for computer server selection in a 
computer network Including a plurality of servers is pre- 
sented. The method comprising determining whether a 
best route has been determined; selecting one of the 
plurality of sen/ers as a best route s erver if the best route 
h as been determin ed: and selecting one of the plurality 
of servers as a selection scheme server scheme if the 
best route has not been determined. The selection of 
the selection scheme server is determined via a selec- 
tion scheme, wherein the selection scheme does not in- 
clude deter mininq Jliai>e st route. 
[0017] A system according to an embodiment of the 
present invention tor computer server selection in a 
computer network is also presented. The system com- 
prises a p lu ra lity^of-Sejve rs : and an authoritative name 
server coupled to the plurality of servers. The authorita- 
tive name server determines whether a best route has 
been determined. It selects one of the plurality of servers 
as a best route sender if the best route has been deter- 
mined, and selects one of the plurality of servers as a 
selection scheme server if the best route has not been 
determined. The selection scheme does not include de- 
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termining the best route. 

Brief Description Of The Drawings 

[0018] Fig. 1 is a diagram illustrating tfie basic organ- 
ization of the Internet. 

[001 9] Fig. 2 is a block diagram illustrating a path tak- 

en by a user's request for a particular address, and the 

path taken in receiving that address. 

[0020] Fig. 3 is a block diagram of a computer system 

in which an embodiment of the present invention can 

reside. 

[0021] Fig. 4 is a system diagram illustrating the data 
flow of the system for providing server selection for mir- 
rored sites according to an embodiment of the present 
invention. 

[0022] Fig. 5 is a flow diagram of a method according 
to an embodiment of the present invention for providing 
server selection for mirrored sites. 
[0023] Fig. 6 is a flow diagram of a method according 
to an embodiment of the present invention for determi- 
nation of best route as recited in step 508 of Fig. 5. 
[0024] Fig. 7 is an alternative method according to an 
embodiment of the present invention for determination 
of best route recited in step 508 of Fig. 5. 

DETAILED DESCRiPTiON OF THE PREFERRED 
ElVIBODIimENTS 

[0025] The following description is presented to ena- 
ble one of ordinary skill in the art to make and to use the 
invention and Is provided In the context of a patent ap- 
plication and its requirements. Various modifications to 
the preferred embodiments will be readily apparent to 
those skilled in the art and the generic principles herein 
may be applied to other embodiments. Thus, the 
present invention is not intended to be limited to the em- 
bodiment shown but is to be accorded the widest scope 
consistent with the principles and features described 
herein. 

[0026] Figure 3 is a block diagram of a general pur- 
pose computer system suitable for carrying out the 
processing in accordance with one embodiment of the 
present invention. Figure 3 Illustrates one embodiment 
of a general purpose computer system. Other computer 
system architectures and configurations can be used for 
carrying out the processing of the present invention. 
Computer system, made up of various subsystems de- 
scribed below, includes at least one microprocessor 
subsystem (also referred to as a central processing unit, 
or CPU) 302. That is. CPU 302 can be Implemented by 
a single-chip processor or by multiple processors. CPU 
302 is a general purpose digital processor which con- 
trols the operation of the computer system. Using in- 
structions retrieved from memory 310, the CPU 302 
controls the reception and manipulation of Input data, 
and the output and display of data on output devices. 
[0027] CPU 302 is coupled bi-directionally with mem- 



ory 310 which can include a first primary storage, typi- 
cally a random access memory (RAM), and a second 
primary storage area, typically a read-only memory 
(ROM). As is well known in the art. primary storage can 
s be used as a general storage area and as scratch -pad 
memory, and can also be used to store input data and 
processed data. It can also store programming instruc- 
tions and data, in the form of data objects and text ob- 
jects, in addition to other data and instructions for proc- 
10 esses operating on CPU 302. Also as well known in the 
art. primary storage typically includes basic operating 
instructions, program code, data and objects used by 
the CPU 302 to perform its functions. Primary storage 
devices 310 may include any suitable computer-reada- 
15 ble storage media, described below, depending on 
whether, for example, data access needs to be bi-direc- 
tional or unl-directional. CPU 302 can also directly and 
very rapidly retrieve and store frequently needed data 
In a cache memory (not shown). 
[0028] A removable mass storage device 312 pro- 
vides additional data storage capacity for the computer 
system, and Is coupled either bi-directionally or uni-dl- 
rectionally to CPU 302. For example, a specific remov- 
able mass storage device commonly known as a CD- 
ROM typically passes data uni-dlrectionally to the CPU 
302, whereas a floppy disk can pass data bi-directionally 
to the CPU 302. Storage 312 may also include compu- 
ter-readable media such as magnetic tape, flash mem- 
ory, signals embodied on a carrier wave, PC-CARDS, 
portable mass storage devices, holographic storage de- 
vices, and other storage devices. A fixed mass storage 
320 can also provide additional data storage capacity. 
The most common example of mass storage 320 is a 
hard disk drive. Mass storage 312, 320 generally store 
additional programming instructions, data, and the like 
that typically are not in active use by the CPU 302. It will 
be appreciated that the information retained within mass 
storage 312, 320 may be incorporated, if needed, in 
standard fashion as part of primary storage 310 (e.g. 
RAM) as virtual memory. 

[0029] In addition to providing CPU 302 access to 
storage subsystems, bus 314 can be used to provide 
access other subsystems and devices as well. In the de- 
scribed embodiment, these can include a display mon- 
itor 318. a network Interface 316, a keyboard 304, and 
a pointing device 306, as well as an auxiliary input/out- 
put device interface, a sound card, speakers, and other 
subsystems as needed. The pointing device 306 may 
be a mouse, stylus, track ball, or tablet, and is useful for 
Interacting with a graphical user interface. 
[0030] The network Interface 316 allows CPU 302 to 
be coupled to another computer, computer network, or 
telecommunications network using a network connec- 
tion as shown. Through the network interface 316, it is 
contemplated that the CPU 302 might receive informa- 
tion, 9,g., data objects or program instructions, from an- 
other network, or might output information to another 
network in the course of performing the above-de- 
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scribed methcxi steps. Information, often represented as 
a sequence of instructions to be executed on a CPU. 
may be received from and outputted to another network, 
for example, in the form of a computer data signal em- 
bodied in a carrier wave. An interface card or similar de- s 
vice and appropriate software implemented by CPU 302 
can be used to connect the computer system to an ex- 
ternal network and transfer data according to standard 
protocols. That is, method embodiments of the present 
invention may execute solely upon CPU 302, or may be io 
performed across a network such as the Internet, intran- 
et networks, or local area networks, in conjunction with 
a remote CPU that shares a portion of the processing. 
Additional mass storage devices (not shown) may also 
be connected to CPU 302 through network interface '5 
316. 

[0031] An auxiliary I/O device interface (not shown) 
can be used in conjunction with computer system. The 
auxiliary I/O device interface can include general and 
customized interfaces that allow the CPU 302 to send 20 
and, more typically receive data from other devices 
such as microphones, touch-sensitive displays, trans- 
ducer card readers, tape readers, voice or handwriting 
recognizers, biometrics readers, cameras, portable 
mass storage devices, and other computers. 25 
[0032] In addition, embodiments of the present inven- 
tion further relate to computer storage products with a 
computer readable medium that contain program code 
for performing various computer-Implemented opera- 
tions. The computer-readable medium is any data stor- 30 
age device that can store data which can thereafter be 
read by a computer system. The media and program 
code may be those specially designed and constructed 
for the purposes of the present invention, or they may 
be of the kind well known to those of ordinary skill in the 35 
computer software arts. Examples of computer-reada- 
ble media include, but are not limited to, all the media 
mentioned above: magnetic media such as hard disks, 
floppy disks, and magnetic tape; optical media such as 
CD-ROM disks; magneto-optical media such as floptical 40 
disks; and specially configured hardware devices such 
as application-specific integrated circuits (ASICs), pro- 
grammable logic devices (PLDs), and ROM and RAM 
devices. The computer-readable medium can also be 
distributed as a data signal embodied in a carrier wave 4S 
over a network of coupled computer systems so that the 
computer-readable code Is stored and executed in a dis- 
tributed fashion. Examples of program code include 
both machine code, as produced, for example, by a 
compiler, or files containing higher level code that may 50 
be executed using an interpreter. 
[0033] It will be appreciated by those skilled in the art 
that the above described hardware and software ele- 
ments are of standard design and construction. Other 
computer systems suitable for use with the invention 5S 
may include additional or fewer subsystems. In addition, 
bus 314 is illustrative of any interconnection scheme 
serving to link the subsystems. The computer system 



shown in Fig. 3 is but an example of a computer system 
suitable for use with the invention. Other computer ar- 
chitectures having different configurations of subsys- 
tems may also be utilized. 

[0034] Fig. 4 is a block diagram of a system according ^ 
to an embodiment of the present invention for providing 
service selection for mirrored sites. Fig. 4 also shows 
the data flow between components. A user 400 sends 
a request for an address to the user's local name service 
402. The local name sen/ice 402 then requests the ad-1 
dress from an Optimizer Name Server (ONS) 404. The 1 
request from the local name server (local NS) 402 may 
route through several sen/ers prior to reaching the ONS 
404. —J 
[0035] The ONS 404 is preferably a name server 
which can specifically ans wer q uerjes, such as name 
qu eries . Although the ONS c an work with m or e than o ne 
name, it is limited to appfasamately t^^or^thr ee names. 
Alternatively, the name server 404 can be a convention- 
al ANS. Accordingly, a conventional AN.S can be used 
either in addition to a ONS or in place of a ONS to handle 
a greater number of narnes. The ONS and the mirrored 
servers are preferably implemented in JAVA™. Further 
details of the functions of the ON^S-wilLbejjescr-ibedJn 
corTjunGtion-witli£lgs*-&.-6>-and 7. 
[0036] The data flow shown in Fig. 4 can best be un- 
derstoc dwhen referreA tp Jn conl unction wjth Figs. 5, 6, 
an d 7. Fig. 5 is a floyv dia grami:)|Amethod according to 
an embodiment of the present invention for server se- 
lection for mirrored sites. Fig. 6 is a flow diagram of a 
method for best route determination of step 508 in Fig. 
5. Fig. 7 Is an alternative method for the best route de- 
termination of step 508 in Fig. 5. 
[0037] The method according to the present invention 
for providing sen/ice selection for mirrored sites can be 
seen in the examples shown in Figs. 4 and 5. The user 
400 requests an address with a name t o the local NS 
(LNS) 402 in s tep 500. The LNS eventually conta ctsand 
r equests the address from tha ONS 404 via step 502. It 
is ^^^flL^i^^''"''"'^'^ thg ON-S a It^est route has al- 
readv-b aen determined for this LNS which is still va lid 
via_step 504. A best route determination Is preferably 
o'nFyjv alid for a predetermined time, such as thirty min- 
utesTlf a best route has been determined for this LNS 
which is still wit hjn the p redetermined time, then the 
ONS 404 replies to the LNS 402 with the best route mir- 
rored server via step 506. 

[0038] If, however, the best route has not been deter- 
mln^djor this LNS, or the predetermined tim e^has e x- 
pired, then the ON S 404 replies to LNS 402 vla^ selec- 
tiocL gcheme, s uch as a round robin scheme, via^ teo 
508. Additionally, if a b est route has not been^ eter- 
mi ned forJhis LNS. a best route determination for the 
LNS is initiated with step 508 . 

[0039] A preferred method^ gcording to an embodi- 
ment ofJhe_present. invention of best.route determina- 
tion (step 508 of Fig. 5) ca n be described in co nnection 
with references to Figs. 4 and 6. In initiating best route 
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determination, the ONS 404 requests fronn all the mir- 
rored servers 406a-406b the round trip time to the LNS 
402 via step 600. Each mirrored server 406a-406b then 
sends a name query to the LNS 402 via step 602. The 
LNS 402 then replies with an error message stating that 
the requested name does not exist via step 604. Each 
mirrored server 406a-406b then determines the round 
trip time from the time the name query was sent to the 
time the error message was received via step 606. Each 
mirrored server 406a and 406b then sends its round trip 
time to the ONS 404 via step 608. The ONS 404 can 
then determine which mirrored server has the best route 
tor this particular LNS 402 via step 610. The best route 
is equivalent to the fastest route. The best route is then 
stored for a predetemnined time via step 61 2. 
[0040] When the LNS 402 requests an address via 
step 614, it is determined whether the pre determined 
time has expired in step 616. If so, then the ONS 404 
replies to the LNS 402 via a selection scheme, such as 
a round robin scheme, via step 620 and a best route 
determination is initiated via step 600. If, however, the 
predetermined time has not expired via step 616, then 
the LNS 402 is assigned to the mirrored server 406 with 
the best route via step 618. 

[0041] An alternative method according to an embod- 
iment of the present invention for the best route deter- 
mination (step 508 of Fig. 5) can be described in con- 
junction with Figs. 4 and 7. The ONS 404 requests from 
all the mirrored servers 406a-406b the round trip time 
to the LNS 402 via step 700. Each mirrored server 406a- 
406b then sends an echo packet to LNS 402 via step 
702. An echo packet is an Internet Control Method Pro- 
tocal (I CMP) packet which is retumed by the receiver 
when the receiver receives the echo packet. Echo pack- 
ets are commonly known in the industry. Each mirrored 
server 406a-406b then receives a return echo packet 
from the LNS 402 via step 704. Each mirrored server 
406a-406b then determines a round trip time and sends 
the round trip time to the ONS 404 via step 706. The 
remaining step 708-718 are the same as steps 610-620 
of Fig. 6. 

[0042] A method and system for providing server se- 
lection for mirrored sites has been disclosed. Software 
written according to the present invention may be stored 
in some form of computer readable medium such as 
memory or CD-ROM or transmitted over a network, and 
executed by a processor. 

[0043] Although the present invention has been de- 
scribed in accordance with the embodiments shown, 
one of ordinary skill in the art will readily recognize that 
there could be variations to the embodiment and these 
variations would be within the spirit and scope of the 
present invention. Accordingly, many modifications may 
be made by one of ordinary skill in the art without de- 
parting from the spirit and scope of the appended 
claims. 



Claims 

1 . A method for computer server selection in a com- 
puter network including a plurality of servers, the 

5 method comprising: 

determining whether a best route has been de- 
termined; 

selecting one of the plurality of servers as a 
'0 best route server if the best route has been de- 

termined; and 

selecting one of the plurality of sen/ers as a se- 
lection scheme server if the best route has not 
been determined, the selection of the selection 
IS scheme server being determined via a selec- 

tion scheme, wherein the selection scheme 
does not include determining the best route. 

2. The method of claim 1 , further including: 

20 

determining if a predetermined time has ex- 
pired if the best route has been determined; and 
selecting a selection scheme server by using a 
selection scheme if the predetermined time has 
2S expired. 

3. The method of claim 1 or 2, wherein the selection 
scheme is a round robin scheme. 

30 4. The method of any of the preceding claims further 
including: 

determining the best route if the best route has 
not been determined, wherein the determina- 
35 tion of best route includes determining a round 

trip time from one of the plurality of servers to 
a local name server 

5. The method of claim 4, wherein the determination 
<o of the round trip time includes sending a name que- 
ry to the local name sen/er and receiving message 
from the local name server. 

6. The method of claim 4, wherein the determination 
45 of the round trip time includes sending an echo 

packet to the local name server and receiving a re- 
turning echo packet from the local name server 



7. The method of any of the preceding claims, wherein 
so the determination of best route includes determin- 
ing a first round trip time from a first one of the plu- 
rality of servers to a local name server and a second 
round trip time from a second one of the plurality of 
servers to the local name server. 

55 

8. The method of claim 7, wherein the first round trip 
time and the second round trip time is compared to 
determine which one of the first and second servers 
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has the best route. 

9. The method of any of the preceding claims, wherein 
the best route Includes a shortest round trip time 
between one of the plurality of servers and a local s 
name server. 

1 0. A system for computer server selection in a compu- 
ter network including a plurality of servers, the sys- 
tem comprising: io 

means for determining whether a best route 
has been determined; 

means for selecting one of the plurality of serv- 
ers as a best route server if the best route has is 
been determined; and 

means for selecting one of the plurality of serv- 
ers as a selection scheme server if the best 
route has not been determined, the selection of 
the selection scheme server being determined 
via a selection scheme, wherein the selection 
scheme does not include determining the best 
route. 

11. A system for computer server selection in a compu- 25 
ter network, the system comprising: 

a plurality of servers; and 
an authoritative name server coupled to the plu- 
rality of servers, wherein the authoritative name 30 
server determines whether a best route has 
been determined, and selects one of the plural- 
ity of servers as a best route server if the best 
route has been determined; and selects one of 
the plurality of servers as a selection scheme 3S 
server, if the best route has not been deter- 
mined, wherein the selection scheme does not 
include determining the best route. 

12. A computer program product for computer server 40 
selection in a computer network including a plurality 

of servers, comprising: 

computer code determining whether a best 
route has been determined; 45 
computer code selecting one of the plurality of 
servers as a best route server if the best route 
has been determined; 

computer code selecting one of the plurality of 
servers as a selection scheme server if the best so 
route has not been determined, the selection of 
the selection scheme server being determined 
via a selection scheme, wherein the selection 
scheme does not include determining the best 
route; and 55 
a computer readable medium that stores the 
computer codes. 
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